

## Arora V Analog to Digital Converter (ADC)

## **User Guide**

UG299-1.0.3E, 02/02/2024

#### Copyright © 2024 Guangdong Gowin Semiconductor Corporation. All Rights Reserved.

**GOWIN** is a trademark of Guangdong Gowin Semiconductor Corporation and is registered in China, the U.S. Patent and Trademark Office, and other countries. All other words and logos identified as trademarks or service marks are the property of their respective holders. No part of this document may be reproduced or transmitted in any form or by any denotes, electronic, mechanical, photocopying, recording or otherwise, without the prior written consent of GOWINSEMI.

#### Disclaimer

GOWINSEMI assumes no liability and provides no warranty (either expressed or implied) and is not responsible for any damage incurred to your hardware, software, data, or property resulting from usage of the materials or intellectual property except as outlined in the GOWINSEMI Terms and Conditions of Sale. All information in this document should be treated as preliminary. GOWINSEMI may make changes to this document at any time without prior notice. Anyone relying on this documentation should contact GOWINSEMI for the current documentation and errata.

## **Revision History**

| Date       | Version | Description                                             |  |
|------------|---------|---------------------------------------------------------|--|
| 05/08/2023 | 1.0E    | Initial version published.                              |  |
| 07/31/2023 | 1.0.1E  | Description of "2.3.1 ADC Conversion Timing" optimized. |  |
| 12/08/2023 | 1.0.2E  | ADC parameter descriptions updated.                     |  |
| 02/02/2024 | 1.0.3E  | Description of ADC input optimized.                     |  |
|            | 1.0.36  | Table 3-3 ADC GUI Parameters updated.                   |  |

## **Contents**

| ii                         |
|----------------------------|
|                            |
| ٧                          |
| 1                          |
| 1                          |
| 1                          |
| 2                          |
| 2                          |
| 3                          |
| 3                          |
| 4                          |
| 4                          |
| 4                          |
| 7                          |
| 7                          |
|                            |
| 8                          |
| 8<br><b>0</b>              |
|                            |
| 0                          |
| <b>0</b>                   |
| <b>0</b><br>10             |
| <b>0</b><br>10<br>10       |
| <b>0</b><br> 0<br> 0<br> 1 |
| 0<br> 0<br> 1<br> 1<br> 1  |
|                            |

|     | 3.2.2 Port Diagram                                  | . 15 |
|-----|-----------------------------------------------------|------|
|     | 3.2.3 Port Description                              | . 16 |
|     | 3.2.4 Parameter Description                         | . 17 |
|     | 3.2.5 ADC Instantiation (Take ADCULC as an Example) | . 20 |
| 4 / | ADC Configuration and Call                          | 22   |
|     | 4.1 ADC Configuration                               | . 22 |
|     | 4.2 Generation Files                                | . 23 |

UG299-1.0.3E ii

## **List of Figures**

| Figure 2-1 ADC Structure Diagram For 25K devices     | 4  |
|------------------------------------------------------|----|
| Figure 2-2 ADC Structure Diagram For 138/75K devices | 6  |
| Figure 2-3 ADC Conversion Timing                     | 7  |
| Figure 3-1 ADC Port Diagram                          | 11 |
| Figure 3-2 ADC Port Diagram                          | 15 |
| Figure 4-1 ADC Configuration                         | 22 |

UG299-1.0.3E

## **List of Tables**

| Table 1-1 Terminology and Abbreviations | 2  |
|-----------------------------------------|----|
| Table 2-1 ADC Timing Parameters         | 8  |
| Table 2-2 ADC Electrical Parameters     | 8  |
| Table 3-1 Terminology and Abbreviations | 10 |
| Table 3-2 ADC Port Description          | 11 |
| Table 3-3 ADC GUI Parameters            | 12 |
| Table 3-4 Terminology and Abbreviations | 15 |
| Table 3-5 ADCULC Port Description       | 16 |
| Table 3-6 ADCLRC Port Description       | 16 |
| Table 3-7 ADCULC GUI Parameters         | 17 |
| Table 3-8 ADCLRC GUI Parameters         | 19 |

UG299-1.0.3E iv

1 About This Guide 1.1 Purpose

# 1 About This Guide

#### 1.1 Purpose

Arora V Analog to Digital Converter (ADC) User Guide is to help you quickly learn the features and usage of Arora V ADC by introducing to the functions, ports, configuration, etc.

#### 1.2 Related Documents

The latest user guides are available on the GOWINSEMI website. You can find the related documents at <a href="https://www.gowinsemi.com">www.gowinsemi.com</a>:

- DS981E, GW5AT series of FPGA Products Data Sheet
- DS1103E, GW5A series of FPGA Products Data Sheet
- DS1104E, GW5AST series of FPGA Products Data Sheet
- DS1108E, GW5AR series of FPGA Products Data Sheet
- DS1115E, GW5AS-25 Data Sheet
- DS1114E, GW5AS-138 Data Sheet
- <u>SUG100</u>, Gowin Software User Guide

UG299-1.0.3E 1(23)

## 1.3 Terminology and Abbreviations

The terminology and abbreviations used in this manual are as shown in Table 1-1.

Table 1-1 Terminology and Abbreviations

| Terminology and Abbreviations | Full Name                       |
|-------------------------------|---------------------------------|
| ADC                           | Analog to Digital Converter     |
| CIC Filter                    | Cascaded Integrator–comb Filter |
| FPGA                          | Field Programmable Gate Array   |
| IP                            | Intellectual Property           |
| OSC                           | Oscillator                      |
| SRAM                          | Static Random Access Memory     |

## 1.4 Support and Feedback

Gowin Semiconductor provides customers with comprehensive technical support. If you have any questions, comments, or suggestions, please feel free to contact us directly using the information provided below.

Website: www.gowinsemi.com

E-mail:<u>support@gowinsemi.com</u>

UG299-1.0.3E 2(23)

2 Overview 2.1 Features

# 2<sub>Overview</sub>

Arora V series of FPGA products integrate eight-channel 10 bits Delta-sigma ADC. It is an ADC with low power, low-leakage current, and high dynamic performance. When combined with the programmable logic capability of the FPGA, the sensor can address the data acquisition and monitoring requirements for by chip internal temperature and power monitoring. FPGA also provides rich and freely configurable GPIO differential interfaces and ADC analog differential signal interfaces to connect to the ADC voltage channels, which can meet the voltage data sampling and monitoring requirements.

#### 2.1 Features

The main features of Arora V ADC are as follows:

- Number of ADC:
  - GW5A-25/ GW5AR-25/ GW5AS-25: 1
  - GW5A-138/ GW5AT-138/ GW5AT-75/ GW5AST-138: 2
- Reference voltage source: Built-in
- Number of channels per ADC: 8
- Bit width accuracy: 10 bits
- Sampling Clock: < 2MHz</li>
- ADC differential input voltage range: 0~1V (positive input voltage > negative input voltage)
- Temperature sensor accuracy: +/-2℃
- Voltage sensor accuracy: +/-5mV

UG299-1.0.3E 3(23)

## 2.2 Functional Description

#### 2.2.1 Overview

Arora V ADC provides analog Delta-sigma modulators to meet the requirements of on-chip temperature and voltage detection in multiple regions, and also provides GPIO differential interfaces for off-chip voltage and temperature input, only supporting differential signal input (Positive input voltage > Negative input voltage).

Arora V ADC has embedded reference voltage source with high accuracy, and it does not require off-chip voltage reference source; Arora V ADC features low power and high accuracy for temperature and supply voltage detection. Arora V ADC has an internally integrated voltage signal processing module, so no external voltage reference source is required. It meets the accuracy of voltage signal measurements and helps to reduce user costs.

#### 2.2.2 Architecture

Figure 2-1 shows the structure diagram of GW5A-25 / GW5AR-25 / GW5AS-25 ADC.



Figure 2-1 ADC Structure Diagram For 25K devices

GW5A-25 / GW5AR-25 / GW5AS-25 ADC supports on-chip temperature and voltage detection. Through the control signal, you can

UG299-1.0.3E 4(23)

select the voltage from the on-chip temperature sensor to enter the on-chip temperature detection mode; or you can select another path to monitor the power supply voltage of IP modules in the FPGA, including bank voltage, core voltage, and SRAM voltage, etc. The off-chip voltage signals can be sent to the ADC via the GPIO differential pins on Bank0/1/2/3/4/5/6/7 or the dedicated ADC differential input pins for ADC quantization.

For GW5A-25 / GW5AR-25 / GW5AS-25 ADC, you can select UserLogic clock or OSC clock to obtain a better balance between power and performance.

The voltage signal into the Delta sigma modulator0 is quantized and noise-shaped to output adc\_1bit0 and adc\_clk0, which can be sent to the embedded CIC hard core or CIC soft core for further processing to obtain the digital characterization of temperature and voltage.

GW5A-138/GW5AT-138/GW5AT-75/GW5AST-138 offers two ADCs. Figure 2-2 shows the structure diagram.

UG299-1.0.3E 5(23)



Figure 2-2 ADC Structure Diagram For 138/75K devices

GW5A-138/GW5AT-138/GW5AT-75/GW5AST-138 supports on-chip temperature and voltage detection. Through the control signal, you can select the voltage from the on-chip temperature sensor to enter the on-chip temperature detection mode; or you can select another path to monitor the power supply voltage of IP modules in the FPGA, including Bank2/3/4/5/6/7/10 voltage, core voltage, MIPI and SERDES voltage, etc. The off-chip voltage signals can be sent to the ADC via the GPIO differential pins on Bank2/3/4/5/6/7 or the dedicated ADC differential input pins for ADC quantization.

For GW5A-138/GW5AT-138/GW5AT-75/GW5AST-138 ADC, you can select user logic clock IO, GPIO clock or OSC clock to obtain a better balance between power and performance.

UG299-1.0.3E 6(23)

2 Overview 2.3 ADC Characteristics

The voltage signal into the Delta\_sigma modulator1/Delta\_sigma modulator2 is quantized and noise-shaped to output adc\_1bit1/adc\_1bit2 and adc\_clk1/adc\_clk2. They can be sent to the embedded CIC hard core for further processing to obtain the digital characterization of temperature and voltage.

In addition, the 138K ADC supports two pairs of dedicated ADC differential input interfaces: adcvp/adcvn, adctp/adctn, providing users with a low-latency, low-noise differential voltage input channel.

#### 2.3 ADC Characteristics

#### 2.3.1 ADC Conversion Timing

There are N clock cycles needed for the ADC to sample analog input signals, convert them to output digital signals, and then generate the output signals. When the rising edge of the sensor\_req signal comes, and the sensor\_en signal is enabled (active-high), the ADC will be triggered to sample once; when the sensor measurement is finished, it will pull the sensor\_rdy signal high to indicate the completion of sampling and output the sampling value of sensor\_value[13:0].

In voltage measurement mode, the output value of sensor\_value is an unsigned number (sensor\_value [13:11] for the integer part and sensor\_value [10:0] for the fractional part), which needs to be divided by 2048 to get the actual measured value in V.

In temperature mode, the output value of sensor\_value is a signed number (sensor\_value [13] for the sign bit, sensor\_value [12:2] for the integer part and sensor\_value [1:0] for the fractional part), which needs to be divided by 4 to get the actual measured value in °C.



**Figure 2-3 ADC Conversion Timing** 

UG299-1.0.3E 7(23)

2 Overview 2.3 ADC Characteristics

**Table 2-1 ADC Timing Parameters** 

| Symbol             | Description         | Spec. | Unit |       |
|--------------------|---------------------|-------|------|-------|
|                    | Description         | Min.  | Max. | Offic |
| CLK                | Clock cycle         | TBD   | TBD  | ns    |
| Ts                 | SOC setup time      | TBD   | TBD  | ns    |
| Тн                 | SOC hold-up time    | TBD   | TBD  | ns    |
| T <sub>D_EOC</sub> | EOC delay time      | TBD   | TBD  | ns    |
| T <sub>D_B</sub>   | Data-out delay time | TBD   | TBD  | ns    |

#### 2.3.2 Electrical Characteristic Parameters

**Table 2-2 ADC Electrical Parameters** 

| Parameter                         | Description               | Spec. |      |      | Unit        |
|-----------------------------------|---------------------------|-------|------|------|-------------|
| Tarameter Description             |                           | Min.  | Тур. | Max. | Unit        |
| DC precision                      |                           |       |      |      |             |
| Output                            | Digital output bits       | -     | 10   | -    | Bit         |
| INL                               | Integral nonlinearity     | -     | TBD  | -    | LSB         |
| DNL                               | Differential nonlinearity | -     | TBD  | -    | LSB         |
| Offset error                      | Offset error              | -     | TBD  | -    | %FS         |
| Gain error                        | Gain error                | -     | TBD  | -    | %FS         |
| Analog Input                      |                           |       |      |      |             |
| CH[7: 0]                          | Single-ended input range  | -     | TBD  | -    | V           |
| CIN                               | Input capacitance         | -     | TBD  | -    | pF          |
| Slew Rate                         | Slew Rate                 |       |      |      |             |
| SoC                               | Sample frequency          | -     | TBD  | -    | MHz         |
| CLK                               | Master Clock              | -     | TBD  | -    | MHz         |
| Date-out delay                    | Date-out delay            | -     | TBD  | -    | Clock cycle |
| Dynamic Characteristic Parameters |                           |       |      |      |             |
| SINAD                             | Signal Noise Ratio        | -     | TBD  | -    | DB          |
| SINAD                             | Signal Noise Natio        | -     | TBD  | -    | DB          |
| SFDR                              | Spurious-free             | -     | TBD  | -    | DB          |
| SFUR                              | dynamic range             | -     | TBD  | -    | DB          |
| ENOB                              | Valid output data         | -     | TBD  | -    | Bit         |
| LINOD                             | bits                      | -     | TBD  | -    | Bit         |

UG299-1.0.3E 8(23)

2 Overview 2.3 ADC Characteristics

| Darameter             | Description         | Spec. |      |      | 11-4 |
|-----------------------|---------------------|-------|------|------|------|
| Parameter Description |                     | Min.  | Тур. | Max. | Unit |
| Digital Input         |                     |       |      |      |      |
| ViH                   | Input high level    | -     | TBD  | -    | V    |
| VIL                   | Input low level     | -     | TBD  | -    | V    |
| Digital output B[9:   | 0]                  |       |      |      |      |
| Vон                   | Output high level   | -     | TBD  | -    | V    |
| VoL                   | Output low level    | -     | TBD  | -    | V    |
| Supply voltage        | Supply voltage      |       |      |      |      |
| $V_{dd\_a}$           | Analog core voltage | -     | TBD  | -    | ٧    |
| V <sub>dd_dig</sub>   | Digital voltage     | -     | TBD  | -    | ٧    |
| Vddx                  | Analog voltage      | -     | TBD  | -    | TBD  |
| I <sub>vdd_a</sub>    | Analog bitstream    | -     | TBD  | -    | uA   |
| Ivdd_dig              | Digital current     | -     | TBD  | -    | uA   |
| l <sub>vddx</sub>     | Analog current      | -     | TBD  | -    | TBD  |
| I <sub>pd</sub>       | Turn-off current    | -     | TBD  | -    | mA   |

UG299-1.0.3E 9(23)

3 ADC 3.1 ADC(25K)

 $3_{ADC}$ 

## 3.1 ADC(25K)

## 3.1.1 Devices Supported

Table 3-1 Terminology and Abbreviations

| Family             | Series | Device    |
|--------------------|--------|-----------|
| Arora <sup>®</sup> | GW5A   | GW5A-25A  |
|                    | GW5AR  | GW5AR-25A |
|                    | GW5AS  | GW5AS-25A |

UG299-1.0.3E 10(23)

3 ADC 3.1 ADC(25K)

## 3.1.2 Port Diagram

Figure 3-1 ADC Port Diagram



## 3.1.3 Port Description

**Table 3-2 ADC Port Description** 

| Port    | I/O   | Description                                  |
|---------|-------|----------------------------------------------|
| clk     | input | clk input                                    |
| drstn   | input | digital part reset signal, active low        |
|         |       | mode selection                               |
| adcmode | input | 1'b0: temperature mode                       |
|         |       | 1'b1:voltage mode                            |
|         | input | input source selection bit [2:0]             |
|         |       | 3'b000: glo_left                             |
|         |       | 3'b001:glo_right                             |
|         |       | 3'b010:loc_left(Corresponding to Bank1 GPIO) |
| vsenctl |       | 3'b011: vtest                                |
|         |       | 3'b100:vcc                                   |
|         |       | 3'b101:vccc                                  |
|         |       | 3'b110:vccm                                  |
|         |       | 3'b111:vccx_buf                              |
| adcen   | input | enable signal, active high                   |

UG299-1.0.3E 11(23)

3.1 ADC(25K)

| Port                 | I/O    | Description                                   |
|----------------------|--------|-----------------------------------------------|
| adcreqi              | input  | measurement request signal, valid rising edge |
| adcrdy               | output | measurement completion signal, active high    |
| adcvalue             | output | bit[13:0] the measurement result output       |
| mdrp_rdata           | output | bit[7:0] mdrp_rdata                           |
| mdrp_clk             | input  | mdrp clock                                    |
| mdrp_wdata           | input  | bit[7:0] mdrp_wdata                           |
| mdrp_a_inc           | input  | mdrp_a_inc                                    |
| mdrp_opcode          | input  | bit[1:0] mdrp_opcode                          |
| tlvds_ibuf_adc_i     | input  | The adcvp signal from bank1                   |
| tlvds_ibuf_adc_ib    | input  | The adcvn signal from bank1                   |
| tlvds_ibuf_adc_adcen | input  | The adc enable signal from bank1              |

## 3.1.4 Parameter Description

**Table 3-3 ADC GUI Parameters** 

| Parameter                             | Default Value                    | Description                                                                                                                        |
|---------------------------------------|----------------------------------|------------------------------------------------------------------------------------------------------------------------------------|
| ADC Select                            | ADC                              | ADC                                                                                                                                |
| ADC Mode                              | Temperature                      | Temperature/Voltage                                                                                                                |
| Division Factor                       | 1                                | clock division 0: /1, 1: /2, 2: /4, 3: /8 Clock after frequency division, 500kHz~8MHz                                              |
| Clock Select                          | OSC                              | clk source<br>osc (2.5MHz) or CLK                                                                                                  |
| Sample Rate                           | 64                               | sample rate configuration 4/8/16/32/64/128                                                                                         |
| Sample Count                          | 1024                             | sample count configuration<br>64/128/256/512/1024/2048                                                                             |
| Fscal Value                           | 730(Temperature)<br>623(Voltage) | temperature mode: 510~948 voltage mode: 452~840                                                                                    |
| Offset                                | -1180(Temperature)<br>0(Voltage) | temperature mode: -1560~-760 voltage mode: -410~410                                                                                |
| Dynamic Bank Enable<br>(Voltage mode) | Unchecked                        | If checked, the tlvds_ibuf_adc ADC input interface (Bank1 input) will be enabled.                                                  |
| glo_left<br>(Voltage mode)            | vcc                              | vcc/vcc_ext/vccio_bk1/vccc/pad The pad corresponds to the bank0/6/7 IOs, referred to as bus0. When using the IOs of these banks as |

UG299-1.0.3E 12(23)

3.1 ADC(25K)

| Parameter                   | Default Value | Description                                                                                                                                                                                                                                                                                                        |
|-----------------------------|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                             |               | ADC inputs, it is necessary to add the physical constraints as follows: USE_ADC_SRC_bus0 loc. loc: the location of the ADC input pin, e.g. IOR26.                                                                                                                                                                  |
| glo_right<br>(Voltage mode) | vcc_reg       | vcc/vcc_reg/vccc/vccm/vccio_bk4/ vccio_bk5/vccio _bk10/pad The pad corresponds to the bank2/3/4/5 IOs, referred to as bus0. When using the IOs of these banks as ADC inputs, it is necessary to add the physical constraints as follows: USE_ADC_SRC_bus1 loc. loc: the location of the ADC input pin, e.g. IOR26. |
| vccx_buf (Voltage mode)     | vccx          | vccx                                                                                                                                                                                                                                                                                                               |

#### 3.1.5 ADC Instantiation

#### **Verilog Instantiation:**

```
Gowin_ADC Gowin_ADC_inst (
    .adcrdy(adcrdy_o),
    .adcvalue(adcvalue_o),
    .mdrp_rdata(mdrp_rdata_o),
    .vsenctl(vsenctl_i),
    .adcen(adcen_i),
    .clk(clk_i),
    .drstn(drstn_i),
    .adcreqi(adcreqi_i),
    .adcmode(adcmode_i),
    .mdrp_clk(mdrp_clk_i),
    .mdrp_wdata(mdrp_wdata_i),
    .mdrp_a_inc(mdrp_a_inc_i),
    .mdrp_opcode(mdrp_opcode_i)
);
```

UG299-1.0.3E 13(23)

3 ADC 3.1 ADC(25K)

#### **Vhdl Instantiation:**

```
component Gowin ADC
    port (
        adcrdy: out std_logic;
        adcvalue: out std_logic_vector(13 downto 0);
        mdrp_rdata: out std_logic_vector(7 downto 0);
        vsenctl: in std_logic_vector(2 downto 0);
        adcen: in std logic;
        clk: in std_logic;
        drstn: in std_logic;
        adcreqi: in std_logic;
        adcmode: in std logic;
        mdrp clk: in std logic;
        mdrp_wdata: in std_logic_vector(7 downto 0);
        mdrp_a_inc: in std_logic;
        mdrp_opcode: in std_logic_vector(1 downto 0)
    );
end component;
Gowin ADC inst: Gowin ADC
    port map (
        adcrdy => adcrdy o,
        adcvalue => adcvalue o,
        mdrp rdata => mdrp rdata o,
        vsenctl => vsenctl i,
        adcen => adcen i,
        clk => clk i,
        drstn => drstn_i,
        adcreqi => adcreqi i,
        adcmode => adcmode i,
        mdrp_clk => mdrp_clk_i,
        mdrp wdata => mdrp wdata i,
```

UG299-1.0.3E 14(23)

3.2 ADC(75K/138K)

```
mdrp_a_inc => mdrp_a_inc_i,
mdrp_opcode => mdrp_opcode_i
);
```

## 3.2 ADC(75K/138K)

## 3.2.1 Devices Supported

Table 3-4 Terminology and Abbreviations

| Family             | Series | Device                             |
|--------------------|--------|------------------------------------|
| Arora <sup>®</sup> | GW5A   | GW5A-138B                          |
|                    | GW5AS  | GW5AS-138B                         |
|                    | GW5AT  | GW5AT-138 / GW5AT-138B / GW5AT-75B |
|                    | GW5AST | GW5AT-138B                         |

#### 3.2.2 Port Diagram

Figure 3-2 ADC Port Diagram



UG299-1.0.3E 15(23)

## 3.2.3 Port Description

**Table 3-5 ADCULC Port Description** 

| Port                 | I/O    | Description                                   |
|----------------------|--------|-----------------------------------------------|
| clk                  | input  | clk input                                     |
| drstn                | input  | digital part reset signal, active low         |
|                      |        | input source selection bit[2:0]               |
|                      |        | 3'b000:vtest                                  |
|                      |        | 3'b001:vdd09_0                                |
| vsenctl              | input  | 3'b010:vdd09_1                                |
| VSCIICU              | Input  | 3'b011:vdd09_2                                |
|                      |        | 3'b100:vdd18_0                                |
|                      |        | 3'b101:vdd18_1                                |
|                      |        | 3'b111:vdd33                                  |
| adcen                | input  | enable signal, active high                    |
| adcreqi              | input  | measurement request signal, valid rising edge |
| adcrdy               | output | measurement completion signal, active high    |
| adcvalue             | output | bit[13:0] the measurement result output       |
|                      | input  | bit[9:0]                                      |
| fscal_value          |        | temperature mode: 510~948                     |
|                      |        | voltage mode: 452~840                         |
|                      |        | bit[11:0]                                     |
| offset_value         | input  | emperature mode: -1560~-760                   |
|                      |        | voltage mode: -410~410                        |
| tlvds_ibuf_adc_i     | input  | The adcvp signal from bank6/7                 |
| tlvds_ibuf_adc_ib    | input  | The adcvn signal from bank6/7                 |
| tlvds_ibuf_adc_adcen | input  | The adc enable signal from bank6/7            |
| adcinbk6a            | input  | adcvp from Bank6 GPIO                         |
| adcinbk6b            | input  | adcvn from Bank6 GPIO                         |
| adcinbk7a            | input  | adcvp from Bank7 GPIO                         |
| adcinbk7b            | input  | adcvn from Bank7 GPIO                         |

**Table 3-6 ADCLRC Port Description** 

| Port  | I/O   | Description                           |
|-------|-------|---------------------------------------|
| CLK   | input | clk input                             |
| DRSTN | input | digital part reset signal, active low |

UG299-1.0.3E 16(23)

| Port                 | I/O    | Description                                   |
|----------------------|--------|-----------------------------------------------|
|                      |        | input source selection bit[2:0]               |
|                      |        | 3'b000: adcv                                  |
|                      |        | 3'b001: adct                                  |
|                      |        | 3'b010: vdd09_0                               |
| VSENCTL              | input  | 3'b011: vdd09_1                               |
|                      |        | 3'b100: vdd18_0                               |
|                      |        | 3'b101: vdd18_1                               |
|                      |        | 3'b110: vdd33_0                               |
|                      |        | 3'b111: vdd33_1                               |
| ADCEN                | input  | enable signal, active high                    |
| ADCREQI              | input  | measurement request signal, valid rising edge |
| ADCRDY               | output | measurement completion signal, active high    |
| ADCVALUE             | output | bit[13:0] the measurement result output       |
|                      |        | bit[9:0]                                      |
| FSCAL_VALUE          | input  | temperature mode: 510~948                     |
|                      |        | voltage mode: 452~840                         |
|                      |        | bit[11:0]                                     |
| OFFSET_VALUE         | input  | emperature mode: -1560~-760                   |
|                      |        | voltage mode: -410~410                        |
| TLVDS_IBUF_ADC_I     | input  | The adcvp signal from bank2/3                 |
| TLVDS_IBUF_ADC_IB    | input  | The adcvn signal from bank2/3                 |
| TLVDS_IBUF_ADC_ADCEN | input  | The adc enable signal from bank2/3            |
| ADCINBK2A            | input  | adcvp from Bank2 GPIO                         |
| ADCINBK2B            | input  | adcvn from Bank2 GPIO                         |
| ADCINBK3A            | input  | adcvp from Bank3 GPIO                         |
| ADCINBK3B            | input  | adcvn from Bank3 GPIO                         |
| ADCINBK4A            | input  | adcvp from Bank4 GPIO                         |
| ADCINBK4B            | input  | adcvn from Bank4 GPIO                         |
| ADCINBK5A            | input  | adcvp from Bank5 GPIO                         |
| ADCINBK5B            | input  | adcvn from Bank5 GPIO                         |

## 3.2.4 Parameter Description

**Table 3-7 ADCULC GUI Parameters** 

| Parameter  | Default Value | Description   |
|------------|---------------|---------------|
| ADC Select | ADCULC        | ADCULC/ADCLRC |

UG299-1.0.3E 17(23)

| Parameter                          | Default Value                    | Description                                                                             |
|------------------------------------|----------------------------------|-----------------------------------------------------------------------------------------|
| ADC Mode                           | Temperature                      | Temperature/Voltage                                                                     |
| Division Factor                    | 1                                | clock division 0: /1, 1: /2, 2: /4, 3: /8 Clock after frequency division, 500kHz~8MHz   |
| Clock Select                       | osc                              | clk source<br>osc(2.5MHz) /CLK/IO                                                       |
| VSEN Control                       | Unchecked                        | vsenctl control port  If checked, the ADC IP generated has no vsenctl signal.           |
| Sample Rate                        | 64                               | sample rate configuration 4/8/16/32/64/128                                              |
| Sample Count                       | 1024                             | sample count configuration<br>64/128/256/512/1024/2048                                  |
| Fscal Value                        | 730(Temperature)<br>623(Voltage) | temperature mode: 510~948 voltage mode: 452~840                                         |
| Offset                             | -1180(Temperature)<br>0(Voltage) | temperature mode: -1560~-760 voltage mode: -410~410                                     |
| Dynamic Bank Enable (Voltage mode) | Unchecked                        | If checked,the tlvds_ibuf_adc ADC input port will be enabled.  (Bank6/7 input)          |
| vtest<br>(Voltage mode)            | vcc                              | vcc                                                                                     |
| vdd09_0<br>(Voltage mode)          | vccm                             | vccm                                                                                    |
| vdd09_1<br>(Voltage mode)          | vdda_serdes_q0                   | vdda_serdes_q0/vddt_serdes_q0/vdda_mipi_m0/<br>vddd_mipi_m0/ vdda_mipi_m1/ vddd_mipi_m1 |
| vdd09_2<br>(Voltage mode)          | ADCINBK6                         | ADCINBK6/vcc/ ADCINBK7                                                                  |
| Vdd18_0<br>(Voltage mode)          | vddh_serdes_q0                   | vddh_serdes_q0/vccx_mipi_m0/ vccx_mipi_m1                                               |
| Vdd18_1<br>(Voltage mode)          | VCCX                             | VCCX                                                                                    |
| Vdd33<br>(Voltage mode)            | vccio_bk6                        | vccio_bk6/vccio_bk7                                                                     |

UG299-1.0.3E 18(23)

**Table 3-8 ADCLRC GUI Parameters** 

| Parameter              | Default Value          | Description                                                   |
|------------------------|------------------------|---------------------------------------------------------------|
| ADC Select             | ADCULC                 | ADCULC/ADCLRC                                                 |
| ADC Mode               | Temperature            | Temperature/Voltage                                           |
| Division Factor        | 1                      | clock division 0: /1, 1: /2, 2: /4, 3: /8                     |
| DIVISION FACIO         | ı                      | Clock after frequency division, 500kHz~8MHz                   |
| Clock Select           | OSC                    | clk source                                                    |
| Oldon delect           | 000                    | osc(2.5MHz) /CLK/IO                                           |
| VSEN Control           | Unchecked              | vsenctl control port                                          |
| VOLIT CONTO            | Chlorideked            | If checked, the ADC IP generated has no vsenctl signal.       |
| Sample Rate            | 64                     | sample rate configuration                                     |
|                        |                        | 4/8/16/32/64/128                                              |
| Sample Count           | 1024                   | sample count configuration                                    |
|                        |                        | 64/128/256/512/1024/2048                                      |
| Fscal Value            | 730(Temperature)       | temperature mode: 510~948                                     |
|                        | 623(Voltage)           | voltage mode: 452~840                                         |
|                        | -<br>1180(Temperature) | temperature mode: -1560~-760                                  |
| Offset                 |                        | voltage mode: -410~410                                        |
|                        | 0(Voltage)             |                                                               |
| Dynamic Bank<br>Enable | Unchecked              | If checked,the tlvds_ibuf_adc ADC input port will be enabled. |
| (Voltage mode)         | Offichecked            | (Bank2/3 input)                                               |
| vdd09 0                | vdda serdes q1         | vdda serdes q1/vddt serdes q1/vcc/ADCINBK2/ADCINBK            |
| (Voltage mode)         | vaaa_55/455_q1         | 3                                                             |
| vdd09_1                | ADCINBK4               | ADCINBK4/vcc/ ADCINBK5                                        |
| (Voltage mode)         |                        |                                                               |
| vdd18 0                | vddh serdes q1         | vddh serdes q1/vccx                                           |
| (Voltage mode)         |                        |                                                               |
| vdd18_1                | vccx                   | vccx                                                          |
| (Voltage mode)         |                        |                                                               |
| vdd33_0                | vccio_bk2              | vccio_bk2/vccio_bk3                                           |
| (Voltage mode)         |                        |                                                               |
| vdd33_1                | vccio_bk4              | vccio_bk4/ vccio_bk5/vccio_bk10                               |
| (Voltage mode)         |                        |                                                               |

UG299-1.0.3E 19(23)

3.2 ADC(75K/138K)

#### 3.2.5 ADC Instantiation (Take ADCULC as an Example)

#### **Verilog Instantiation:**

```
Gowin ADC Gowin ADC inst(
            .adcrdy(adcrdy o), //output adcrdy
            .adcvalue(adcvalue_o), //output [13:0] adcvalue
            .adcinbk6a(adcinbk6a i), //input adcinbk6a
            .adcinbk6b(adcinbk6b i), //input adcinbk6b
            .adcinbk7a(adcinbk7a i), //input adcinbk7a
            .adcinbk7b(adcinbk7b i), //input adcinbk7b
            .vsenctl(vsenctl i), //input [2:0] vsenctl
            .adcen(adcen i), //input adcen
            .clk(clk i), //input clk
            .drstn(drstn_i), //input drstn
            .adcreqi(adcreqi_i) //input adcreqi
       );
VhdI Instantiation:
       component Gowin ADC
            port (
                adcrdy: out std_logic;
                adcvalue: out std_logic_vector(13 downto 0);
                adcinbk6a: in std logic;
                adcinbk6b: in std logic;
                adcinbk7a: in std logic;
                adcinbk7b: in std_logic;
                vsenctl: in std_logic_vector(2 downto 0);
                adcen: in std_logic;
                clk: in std logic;
                drstn: in std logic;
                adcregi: in std logic
            );
       end component;
```

UG299-1.0.3E 20(23)

3.2 ADC(75K/138K)

```
Gowin_ADC_inst: Gowin_ADC

port map (

adcrdy => adcrdy_o,

adcvalue => adcvalue_o,

adcinbk6a => adcinbk6a_i,

adcinbk7b => adcinbk7a_i,

adcinbk7b => adcinbk7b_i,

vsenctl => vsenctl_i,

adcen => adcen_i,

clk => clk_i,

drstn => drstn_i,

adcreqi => adcreqi_i

);
```

UG299-1.0.3E 21(23)

# 4 ADC Configuration and Call

You can click "Tools > IP Core Generator" in Gowin Software to call and configure ADC.

The following description takes the GW5A-25 ADC call as an example.

## 4.1 ADC Configuration

The ADC configuration interface is shown in Figure 4-1.

Figure 4-1 ADC Configuration



UG299-1.0.3E 22(23)

#### 4.2 Generation Files

After ADC configuration, it will generate three files that are named after the "File Name". Take the default configuration as an example:

- "gowin\_adc.v" file is a complete Verilog module to generate instance Gowin\_ADC;
- "gowin\_adc\_tmp.v" is a template file for IP designs;
- "gowin\_adc.ipc" file is an IP configuration file for users to load and configure the IP.

#### Note!

If VHDL is selected as the hardware description language, the first two files will be named with .vhd suffix.

UG299-1.0.3E 23(23)

